Claims 

What is claimed is: 

1 /I . A method of priority queue dispatching in a data processing system, 

2 wherein: 

3 a critical section of code for a task is when the task has at least one of 

4 a plurality of locks locked; and 

5 said method comprises: 

6 A) dispatching a first task for execution at a temporary dispatching 

7 priority higher than a standard dispatching priority for that first 

8 task whenever the first task is in a critical section of code for 

9 that first task, wherein the critical section of code for that first 

10 task is a result of that first task having locked a first lock 

11 without having unlocked the first lock; and 

12 B) dispatching the first task for execution at the standard dispatching 

13 priority for that first task whenever the first task is not in the 

14 critical section of code for that first task. 

1 2. The method in claim 1 wherein: 

2 the method further comprises: 

3 C) queuing a second task in a first FIFO queue when the second task 

4 attempts to lock the first lock and fails, wherein: 

5 the FIFO queue comprises a set of tasks waiting to lock the first 

6 lock; and 

7 step (C) comprises: 

8 1) placing the second task at an end of the first FIFO queue; 

9 2) comparing the temporary dispatching priority for a third 

10 task that is ahead of the second task in the FIFO queue to 

11 the temporary dispatching priority of the second task; and 

12 3) setting the temporary dispatching priority of the third 

13 task to the temporary dispatching priority of the second 

14 task when the temporary dispatching priority of the 

15 second task is determined in substep (2) to be greater 

16 than the temporary dispatching priority of the third task. 
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The method in claim 2 wherein: 
step (C) further comprises: 

4) setting the temporary dispatching priority for the second task to the 
standard dispatching priority for the second task before substep 
(2) and (3). 

The method in claim 1 wherein: 
the method further comprises: 

C) queuing a second task in a first FIFO queue when the second task 
attempts to lock the first lock and fails, wherein: 
the FIFO queue comprises a set of tasks waiting to lock the first 

lock; and 
step (C) comprises: 

1) placing the second task at an end of the first FIFO queue; 

2) comparing the temporary dispatching priority for the first 
task to the temporary dispatching priority of the second 
task; and 

3) setting the temporary dispatching priority of the first task 
to the temporary dispatching priority of the second task 
when the temporary dispatching priority of the second 
task is determined in substep (2) to be greater than the 
temporary dispatching priority of the first task. 
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1 5. The method in claim 4 wherein step (C) further comprises: 

2 4) testing whether the first task is in a second FIFO queue awaiting a 

3 chance to lock a second lock; and 

4 5) upgrading the temporary dispatching priority of a third task that 

5 has a second lock locked when the first task is determined in 

6 substep (4) to be in the second FIFO queue awaiting a chance to 

7 lock the second lock, wherein substep (5) comprises: 

8 a) comparing the temporary dispatching priority for the 

9 third task to the temporary dispatching priority of the 

10 second task; and 

11 b) setting the temporary dispatching priority of the third 

12 task to the temporary dispatching priority of the second 

13 task when the temporary dispatching priority of the 

14 second task is determined to be greater than the 
^ 15 temporary dispatching priority of the third task. 

03 16. The method in claim 5 wherein: 

p 2 the method further comprises: 

j= 3 D) comparing a highest temporary dispatching priority of any task in 
5 4 the first FIFO queue to the temporary dispatching priority of the 

5 first task after the first task unlocks the second lock; and 

nj 6 E) setting the temporary dispatching priority of the first task to the 

7 highest temporary dispatching priority of any task in the first 

p 8 FIFO queue when the temporary dispatching priority of the first 

9 task is determined in step (D) to be greater than the highest 

10 temporary dispatching priority of any task in the first FIFO 

11 queue. 
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1 7. The method in claim 4 wherein: 

2 step (c) further comprises: 

3 4) comparing the temporary dispatching priority for a third task that is 

4 ahead of the second task in the first FIFO queue to the 

5 temporary dispatching priority of the second task; and 

6 5) setting the temporary dispatching priority of the third task to the 

7 temporary dispatching priority of the second task when the 

8 temporary dispatching priority of the second task is determined 

9 in substep (4) to be greater than the temporary dispatching 
10 priority of the third task. 

1 8. The method in claim 1 wherein: 

2 the temporary dispatching priority for the first task is determined 
^1 3 dynamically and adjusted dynamically depending on the 

4 temporary dispatching priority for other tasks behind the first 

y; 5 task in a first FIFO queue associated with the first lock. 

m 

4= 19. The method in claim 1 wherein: 

L-i 

21 2 the temporary dispatching priority for the first task is a system wide 
B 3 value. 

las 

hi 

fij 1 10. The method in claim 1 wherein: 

2 the temporary dispatching priority for the first task is a value 

3 associated with the first lock when the first lock is a last lock 

4 that the first task has attempted to lock. 
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1 ^11. Software stored in a Computer Software Storage Medium for priority 

2 queue dispatching in a data processing system, wherein: 

3 a critical section of code for a task is when the task has at least one of 

4 a plurality of locks locked; and 

5 said software comprises: 

6 A) dispatching a first task for execution at a temporary dispatching 

7 priority higher than a standard dispatching priority for that first 

8 task whenever the first task is in a critical section of code for 

9 that first task, wherein the critical section of code for that first 

10 task is a result of that first task having locked a first lock 

11 without having unlocked the first lock; and 

12 B) dispatching the first task for execution at the standard dispatching 

13 priority for that first task whenever the first task is not in the 

14 critical section of code for that first task. 

1 12. The software in claim 1 1 wherein: 

2 the software further comprises: 

3 C) queuing a second task in a first FIFO queue when the second task 

4 attempts to lock the first lock and fails, wherein: 

5 the FIFO queue comprises a set of tasks waiting to lock the first 

6 lock; and 

7 set (C) comprises: 

8 1) placing the second task at an end of the first FIFO queue; 

9 2) comparing the temporary dispatching priority for a third 

10 task that is ahead of the second task in the FIFO queue to 

11 the temporary dispatching priority of the second task; and 

12 3) setting the temporary dispatching priority of the third 

13 task to the temporary dispatching priority of the second 

14 task when the temporary dispatching priority of the 

15 second task is determined in subset (2) to be greater than 

16 the temporary dispatching priority of the third task. 
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1 13. The software in claim 12 wherein: 

2 set (C) further comprises: 

3 4) setting the temporary dispatching priority for the second task to the 

4 standard dispatching priority for the second task before subset 

5 (2) and (3). 

1 14. The software in claim 1 1 wherein: 

2 the software further comprises: 

3 C) queuing a second task in a first FIFO queue when the second task 

4 attempts to lock the first lock and fails, wherein: 

5 the FIFO queue comprises a set of tasks waiting to lock the first 

6 lock; and 

7 set (C) comprises: 

^« 8 1) placing the second task at an end of the first FIFO queue; 

4i 9 2) comparing the temporary dispatching priority for the first 

10 task to the temporary dispatching priority of the second 

pj 11 task; and 

4 J 12 3) setting the temporary dispatching priority of the first task 

jn 13 to the temporary dispatching priority of the second task 

5 14 when the temporary dispatching priority of the second 

15 task is determined in subset (2) to be greater than the 

jl] 16 temporary dispatching priority of the first task. 
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1 15. The software in claim 14 wherein set (C) ftirther comprises: 

2 4) testing whether the first task is in a second FIFO queue awaiting a 

3 chance to lock a second lock; and 

4 5) upgrading the temporary dispatching priority of a third task that 

5 has a second lock locked when the first task is determined in 

6 subset (4) to be in the second FIFO queue awaiting a chance to 

7 lock the second lock, wherein subset (5) comprises: 

8 a) comparing the temporary dispatching priority for the 

9 third task to the temporary dispatching priority of the 

10 second task; and 

11 b) setting the temporary dispatching priority of the third 

12 task to the temporary dispatching priority of the second 

13 task when the temporary dispatching priority of the 

14 second task is determined to be greater than the 

15 temporary dispatching priority of the third task. 

1 16. The software in claim 15 wherein: 

2 the software further comprises: 

3 D) comparing a highest temporary dispatching priority of any task in 

4 the first FIFO queue to the temporary dispatching priority of the 

5 first task after the first task unlocks the second lock; and 

6 E) setting the temporary dispatching priority of the first task to the 

7 highest temporary dispatching priority of any task in the first 

8 FIFO queue when the temporary dispatching priority of the first 

9 task is determined in set (D) to be greater than the highest 

10 temporary dispatching priority of any task in the first FIFO 

11 queue. 
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1 17. The software in claim 14 wherein: 

2 set (c) further comprises: 

3 4) comparing the temporary dispatching priority for a third task that is 

4 ahead of the second task in the first FIFO queue to the 

5 temporary dispatching priority of the second task; and 

6 5) setting the temporary dispatching priority of the third task to the 

7 temporary dispatching priority of the second task when the 

8 temporary dispatching priority of the second task is determined 

9 in subset (4) to be greater than the temporary dispatching 
10 priority of the third task. 

1 18, The software in claim 1 1 wherein: 

2 the temporary dispatching priority for the first task is determined 
, 3 dynamically and adjusted dynamically depending on the 

^1 4 temporary dispatching priority for other tasks behind the first 

^ 5 task in a first FIFO queue associated with the first lock. 



m 

M 1 19. The software in claim 1 1 wherein: 

2 the temporary dispatching priority for the first task is a system wide 

3 value. 

1 20. The software in claim 1 1 wherein: 
Ql 2 the temporary dispatching priority for the first task is a value 

3 associated with the first lock when the first lock is a last lock 

4 that the first task has attempted to lock. 
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1.21. A computer readable Non- Volatile Storage Medium encoded with 



2 software for priority queue dispatching in a data processing system, 

3 wherein: 

4 a critical section of code for a task is when the task has at least one of 

5 a plurality of locks locked; and 

6 said software comprises: 

7 A) dispatching a first task for execution at a temporary dispatching 

8 priority higher than a standard dispatching priority for that first 

9 task whenever the first task is in a critical section of code for 

10 that first task, wherein the critical section of code for that first 

11 task is a result of that first task having locked a first lock 

12 without having unlocked the first lock; and 

13 B) dispatching the first task for execution at the standard dispatching 
Q 14 priority for that first task whenever the first task is not in the 
41 15 critical section of code for that first task. 
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